import Vue from "vue";
import Router from "vue-router";
import store from "@/store";
Vue.use(Router);
import { Dialog } from "vant";
import qs from "qs";
/* Layout */
import Layout from "@/layout";
// import { getToken } from '@/utils/auth' // get token from cookie
/* Router Modules */
// import componentsRouter from './modules/components'
// import chartsRouter from './modules/charts'
// import tableRouter from './modules/table'
// import nestedRouter from './modules/nested'

/**
 * Note: sub-menu only appear when route children.length >= 1
 * Detail see: https://panjiachen.github.io/vue-element-admin-site/guide/essentials/router-and-nav.html
 *
 * hidden: true                   if set true, item will not show in the sidebar(default is false)
 * alwaysShow: true               if set true, will always show the root menu
 *                                if not set alwaysShow, when item has more than one children route,
 *                                it will becomes nested mode, otherwise not show the root menu
 * redirect: noRedirect           if set noRedirect will no redirect in the breadcrumb
 * name:'router-name'             the name is used by <keep-alive> (must set!!!)
 * meta : {
    roles: ['admin','editor']    control the page roles (you can set multiple roles)
    title: 'title'               the name show in sidebar and breadcrumb (recommend set)
    icon: 'svg-name'             the icon show in the sidebar
    noCache: true                if set true, the page will no be cached(default is false)
    affix: true                  if set true, the tag will affix in the tags-view
    breadcrumb: false            if set false, the item will hidden in breadcrumb(default is true)
    activeMenu: '/example/list'  if set path, the sidebar will highlight the path you set
  }
 */

/**
 * constantRoutes
 * a base page that does not have permission requirements
 * all roles can be accessed
 */
export const constantRoutes = [
  {
    path: "/redirect",
    component: Layout,
    hidden: true,
    children: [
      {
        path: "/redirect/:path*",
        component: () => import("@/views/redirect/index"),
      },
    ],
  },
  {
    path: "/login",
    component: () => import("@/views/login/index"),
    hidden: true,
    beforeEnter: (to, from, next) => {
      // 判断是否在企业微信打开
      const wx = /wxwork/i;
      const value = wx.test(navigator.userAgent);
      if (value) {
        const appid = "ww684c85420b9d1f76";
        const agentid = "1000013";
        const redirect_uri = window.encodeURIComponent(
          "https://work.cdwlxcs.com/#/login"
        );
        const response_type = "code";
        const scope = "snsapi_privateinfo";
        const state = 1;
        const { code } = qs.parse(location.search.slice(1));
        if (code) {
          // 直接登录
          store
            .dispatch("user/login", { wxcode: code })
            .then(() => {
              next({ path: "/", query: {} });
            })
            .catch(() => {
              next(false);
              Dialog.alert({
                message: "微信登录授权失败",
              }).then(() => {
                // on close
                location.href = "https://work.cdwlxcs.com/#/login";
              });
            });
        } else {
          // 请求授权
          window.open(
            `https://open.weixin.qq.com/connect/oauth2/authorize?appid=${appid}&redirect_uri=${redirect_uri}&response_type=${response_type}&scope=${scope}&state=${state}&agentid=${agentid}#wechat_redirect`,
            "_self"
          );
        }
      } else {
        next();
      }
    },
  },
  {
    path: "/auth-redirect",
    component: () => import("@/views/login/auth-redirect"),
    hidden: true,
  },
  {
    path: "/404",
    component: () => import("@/views/error-page/404"),
    hidden: true,
  },
  {
    path: "/401",
    component: () => import("@/views/error-page/401"),
    hidden: true,
  },
  {
    path: "/",
    component: Layout,
    redirect: "/dashboard",
    children: [
     
      {
        path: "dashboard",
        component: () => import("@/views/dashboard/index"),
        name: "工单首页",
        meta: { title: "工单首页", icon: "dashboard", affix: true },
      },
    ],
  },
  // {
  //   path: "/newIndex",
  //   component: Layout,
  //   redirect: "/newIndex/index",
  //   children: [{
  //     path: "index",
  //     component: () => import("@/views/dashboard/newIndex/index.vue"),
  //     name: "首页",
  //     meta: { title: "首页", icon: "dashboard", affix: true },
  //   }]
  // },
  {
    path: "/profile",
    component: Layout,
    redirect: "/profile/index",
    hidden: true,
    children: [
      {
        path: "index",
        component: () => import("@/views/profile/index"),
        name: "个人中心",
        meta: { title: "个人中心", icon: "user", noCache: true },
      },
    ],
  },
];

/**
 * asyncRoutes
 * the routes that need to be dynamically loaded based on user roles
 */
export const asyncRoutes = [];

const createRouter = () =>
  new Router({
    // mode: 'history', // require service support
    scrollBehavior: () => ({ y: 0 }),
    routes: constantRoutes,
  });

const router = createRouter();

// Detail see: https://github.com/vuejs/vue-router/issues/1234#issuecomment-357941465
export function resetRouter() {
  const newRouter = createRouter();
  router.matcher = newRouter.matcher; // reset router
}

export default router;
